<?php
/**
 * dede接口 Utf-8
 * 自己改文件名  如 biubiubiu.php  并放到dedecms后台目录下
 * 填写接口：
 * http://www.xxx.com/dede/biubiubiu.php
 *
 */
$password = '这里设置接口密码';
$postdata = $_POST ?? [];
$postdata['password'] = isset($postdata['password']) ? $postdata['password'] : "";
$postdata['title'] = isset($postdata['title']) ? $postdata['title'] : "";
$postdata['keyword'] = isset($postdata['keyword']) ? $postdata['keyword'] : "";
$postdata['description'] = isset($postdata['description']) ? $postdata['description'] : "";
$postdata['content'] = isset($postdata['content']) ? $postdata['content'] : "";
$postdata['head_pic'] = isset($postdata['head_pic']) ? $postdata['head_pic'] : "";
$postdata['imgs'] = isset($postdata['imgs']) ? $postdata['imgs'] : "";
$postdata['category'] = isset($postdata['category']) ? $postdata['category'] : "";
$postdata['category_ids'] = isset($postdata['category_ids']) ? $postdata['category_ids'] : "";
$postdata['channelid'] = isset($postdata['channelid']) ? $postdata['channelid'] : "1";
if ($password != $postdata['password']) {
    exit('验证密码错误');
}
define('DEDEADMIN', str_replace("\\", '/', dirname(__FILE__)));
require_once(DEDEADMIN . '/../include/common.inc.php');
require_once(DEDEINC . '/userlogin.class.php');
$userinfo = $dsql->GetOne("SELECT * FROM `#@__admin` limit 1");
if (!$userinfo) exit("userid不存在");
$cuserLogin = new userLogin();
$cuserLogin->userID = $userinfo['id'];
$cuserLogin->userType = $userinfo['usertype'];
$cuserLogin->userChannel = $userinfo['typeid'];
$cuserLogin->userName = $userinfo['uname'];
$cuserLogin->userPurview = $userinfo['purviews'];
//require_once(dirname(__FILE__).'/config.php');
//CheckPurview('a_New,a_AccNew');
require_once(DEDEINC . '/customfields.func.php');
require_once(DEDEADMIN . '/inc/inc_archives_functions.php');
if (file_exists(DEDEDATA . '/template.rand.php')) {
    require_once(DEDEDATA . '/template.rand.php');
}
if (empty($dopost)) $dopost = '';
//
$channelid = 1;
if ($postdata['channelid']) {
    $channelid = $postdata['channelid'];
}
$cid = $postdata['category_ids'];
if (strpos($cid, ',') !== FALSE) {
    $cids = explode(',', $cid);
    $cid = $cids[mt_rand(0, count($cids) - 1)];
    echo "随机分类CID:" . $cid;
}
$title = $postdata['title'];
//$title =  iconv("UTF-8","gbk//TRANSLIT",$title);
$icon = $postdata['head_pic'];
$postkeywords = $postdata['keyword'];
//$postkeywords =  iconv("UTF-8","gbk//TRANSLIT",$postkeywords);
$body = $postdata['content'];
//$body =  iconv("UTF-8","gbk//TRANSLIT",$body);
$description = $postdata['description'];
//$description =  iconv("UTF-8","gbk//TRANSLIT",$description);
//shorttitle
$postshorttitle = $postdata['title'];
if (is_file('kw.txt')) {
    $kw = file_get_contents("kw.txt");
    $kws = explode("\n", $kw);
    $randomkw = $kws[mt_rand(0, count($kws) - 1)];
    $randomkw = str_replace("{标题}", $postdata['title'], $randomkw);
    $title = $randomkw;
}
//图片处理
$postdata['imgs'] = str_replace('-internal.', '.', $postdata['imgs']);
$postdata['head_pic'] = str_replace('-internal.', '.', $postdata['head_pic']);
$picfolder = $cfg_image_dir . "/" . MyDate("Y-m", time()) . '/';
CreateDir($picfolder);
$pics = explode(',', $postdata['imgs']);
$imgurls = "";
foreach ($pics as $p) {
    if (!strstr($p, 'http')) {
        continue;
    }
    //下载图片
    ///d/file/96kaifa/201905071625/20170411084745823.png
    $file = pathinfo($p);
    $picfilename = $file['basename'];
    $img = file_get_contents($p);
    $localpath = $picfolder . $picfilename;
    file_put_contents('../' . $localpath, $img);
    $imginfos = GetImageSize($localpath, $info);
    $imgurls .= "<p><img src='$localpath'/></p>\r\n";
}
$body = $body . "\n<br />\n" . $imgurls;
//图标
if (strstr($postdata['head_pic'], 'http')) {
    $file = pathinfo($postdata['head_pic']);
    $picfilename = $file['basename'];
    $img = file_get_contents($postdata['head_pic']);
    $localpath = $picfolder . $picfilename;
    file_put_contents('../' . $localpath, $img);
    $postlitpic = $localpath;
}
error_reporting(-1);
$dopost = 'save';
if ($dopost != 'save') {
    require_once(DEDEINC . "/dedetag.class.php");
    require_once(DEDEADMIN . "/inc/inc_catalog_options.php");
    ClearMyAddon();
    $channelid = empty($channelid) ? 0 : intval($channelid);
    $cid = empty($cid) ? 0 : intval($cid);
    if (empty($geturl)) $geturl = '';
    $keywords = $writer = $source = $body = $description;
    //采集单个网页
    if (preg_match("#^http:\/\/#", $geturl)) {
        require_once(DEDEADMIN . "/inc/inc_coonepage.php");
        $redatas = CoOnePage($geturl);
        extract($redatas);
    }
    //获得频道模型ID
    if ($cid > 0 && $channelid == 0) {
        $row = $dsql->GetOne("Select channeltype From `#@__arctype` where id='$cid'; ");
        $channelid = $row['channeltype'];
    } else {
        if ($channelid == 0) {
            $channelid = 1;
        }
    }
    //获得频道模型信息
    $cInfos = $dsql->GetOne(" Select * From  `#@__channeltype` where id='$channelid' ");
    //获取文章最大id以确定当前权重
    $maxWright = $dsql->GetOne("SELECT COUNT(*) AS cc FROM #@__archives");
    include DedeInclude("templets/article_add.htm");
    exit();
} else if ($dopost == 'save') {

    require_once(DEDEINC . '/image.func.php');
    require_once(DEDEINC . '/oxwindow.class.php');
    $flag = isset($flags) ? join(',', $flags) : '';
    $notpost = isset($notpost) && $notpost == 1 ? 1 : 0;
    if (empty($typeid2)) $typeid2 = '';
    if (!isset($autokey)) $autokey = 0;
    if (!isset($remote)) $remote = 0;
    if (!isset($dellink)) $dellink = 0;
    if (!isset($autolitpic)) $autolitpic = 0;
    if (empty($click)) $click = ($cfg_arc_click == '-1' ? mt_rand(50, 200) : $cfg_arc_click);
    $typeid = $cid;
    if (empty($typeid)) {
        ShowMsg("请指定文档的栏目！", "-1");
        exit();
    }
    if (empty($channelid)) {
        ShowMsg("文档为非指定的类型，请检查你发布内容的表单是否合法！", "-1");
        exit();
    }
    if (!CheckChannel($typeid, $channelid)) {
        ShowMsg("你所选择的栏目与当前模型不相符，请选择白色的选项！", "-1");
        exit();
    }
    if (!TestPurview('a_New')) {
        //CheckCatalog($typeid,"对不起，你没有操作栏目 {$typeid} 的权限！");
    }
    //对保存的内容进行处理
    if (empty($writer)) $writer = $cuserLogin->getUserName();
    if (empty($source)) $source = '未知';
    $pubdate = time();//GetMkTime($pubdate);
    $senddate = time();
    $sortrank = 0;//AddDay($pubdate,$sortup);
    $ismake = 1;// $ishtml==0 ? -1 : 0;
    $title = preg_replace("#\"#", '＂', $title);
    $title = dede_htmlspecialchars(cn_substrR($title, $cfg_title_maxlen));
    $shorttitle = $postshorttitle;// cn_substrR($shorttitle,36);
    $color = '';// cn_substrR($color,7);
    $writer = cn_substrR($writer, 20);
    $source = cn_substrR($source, 30);
    $description = cn_substrR($description, $cfg_auot_description);
    $keywords = cn_substrR($keywords, 60);
    $filename = trim(cn_substrR($filename, 40));
    $userip = GetIP();
    $isremote = (empty($isremote) ? 0 : $isremote);
    $serviterm = empty($serviterm) ? "" : $serviterm;
    if (!TestPurview('a_Check,a_AccCheck,a_MyCheck')) {
        $arcrank = 0;
    }
    $adminid = $cuserLogin->getUserID();
    //处理上传的缩略图
    if (empty($ddisremote)) {
        $ddisremote = 0;
    }
    $picname = $postlitpic;
    $litpic = GetDDImage('none', $picname, $ddisremote);
    //生成文档ID
    $arcID = GetIndexKey($arcrank, $typeid, $sortrank, $channelid, $senddate, $adminid);
    if (empty($arcID)) {
        ShowMsg("无法获得主键，因此无法进行后续操作！", "-1");
        exit();
    }
    if (trim($title) == '') {
        ShowMsg('标题不能为空', '-1');
        exit();
    }
    //处理body字段自动摘要、自动提取缩略图等
    $body = AnalyseHtmlBody($body, $description, $litpic, $keywords, 'htmltext');
    //自动分页
    $sptype = "";
    if ($sptype == 'auto') {
        $body = SpLongBody($body, $spsize * 1024, "#p#分页标题#e#");
    }
    //分析处理附加表数据
    $inadd_f = $inadd_v = '';
    if (!empty($dede_addonfields)) {
        $addonfields = explode(';', $dede_addonfields);
        if (is_array($addonfields)) {
            foreach ($addonfields as $v) {
                if ($v == '') continue;
                $vs = explode(',', $v);
                if ($vs[1] == 'htmltext' || $vs[1] == 'textdata') {
                    ${$vs[0]} = AnalyseHtmlBody(${$vs[0]}, $description, $litpic, $keywords, $vs[1]);
                } else {
                    if (!isset(${$vs[0]})) ${$vs[0]} = '';
                    ${$vs[0]} = GetFieldValueA(${$vs[0]}, $vs[1], $arcID);
                }
                $inadd_f .= ',' . $vs[0];
                $inadd_v .= " ,'" . ${$vs[0]} . "' ";
            }
        }
    }
    //处理图片文档的自定义属性
    if ($litpic != '' && !preg_match("#p#", $flag)) {
        $flag = ($flag == '' ? 'p' : $flag . ',p');
    }
    $redirecturl = "";
    if ($redirecturl != '' && !preg_match("#j#", $flag)) {
        $flag = ($flag == '' ? 'j' : $flag . ',j');
    }
    //跳转网址的文档强制为动态
    if (preg_match("#j#", $flag)) $ismake = -1;
    $money = "";
    $voteid = "";
    $weight = "";
    $tags = "";
    //保存到主表
    $query = "INSERT INTO `#@__archives`(id,typeid,typeid2,sortrank,flag,ismake,channel,arcrank,click,money,title,shorttitle,
    color,writer,source,litpic,pubdate,senddate,mid,voteid,notpost,description,keywords,filename,dutyadmin,weight)
    VALUES ('$arcID','$typeid','$typeid2','$sortrank','$flag','$ismake','$channelid','$arcrank','$click','$money',
    '$title','$shorttitle','$color','$writer','$source','$litpic','$pubdate','$senddate',
    '$adminid','$voteid','$notpost','$description','$keywords','$filename','$adminid','$weight');";
    if (!$dsql->ExecuteNoneQuery($query)) {
        $gerr = $dsql->GetError();
        $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
        ShowMsg("把数据保存到数据库主表 `#@__archives` 时出错，请把相关信息提交给DedeCms官方。" . str_replace('"', '', $gerr), "javascript:;");
        exit();
    }
    //保存到附加表
    $cts = $dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id='$channelid' ");
    $addtable = trim($cts['addtable']);
    if (empty($addtable)) {
        $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$arcID'");
        $dsql->ExecuteNoneQuery("DELETE FROM `#@__arctiny` WHERE id='$arcID'");
        ShowMsg("没找到当前模型[{$channelid}]的主表信息，无法完成操作！。", "javascript:;");
        exit();
    }
    $useip = GetIP();
    $templet = empty($templet) ? '' : $templet;
    $query = "INSERT INTO `{$addtable}`(aid,typeid,redirecturl,templet,userip,body{$inadd_f}) Values('$arcID','$typeid','$redirecturl','$templet','$useip','$body'{$inadd_v})";
    if (!$dsql->ExecuteNoneQuery($query)) {
        $gerr = $dsql->GetError();
        $dsql->ExecuteNoneQuery("Delete From `#@__archives` where id='$arcID'");
        $dsql->ExecuteNoneQuery("Delete From `#@__arctiny` where id='$arcID'");
        ShowMsg("把数据保存到数据库附加表 `{$addtable}` 时出错，请把相关信息提交给DedeCms官方。" . str_replace('"', '', $gerr), "javascript:;");
        exit();
    }
    //生成HTML
    InsertTags($tags, $arcID);
    if ($cfg_remote_site == 'Y' && $isremote == "1") {
        if ($serviterm != "") {
            list($servurl, $servuser, $servpwd) = explode(',', $serviterm);
            $config = array('hostname' => $servurl, 'username' => $servuser, 'password' => $servpwd, 'debug' => 'TRUE');
        } else {
            $config = array();
        }
        if (!$ftp->connect($config)) exit('Error:None FTP Connection!');
    }
    $picTitle = FALSE;
    if (count($_SESSION['bigfile_info']) > 0) {
        foreach ($_SESSION['bigfile_info'] as $k => $v) {
            if (!empty($v)) {
                $pictitle = ${'picinfook' . $k};
                $titleSet = '';
                if (!empty($pictitle)) {
                    $picTitle = TRUE;
                    $titleSet = ",title='{$pictitle}'";
                }
                $dsql->ExecuteNoneQuery("UPDATE `#@__uploads` SET arcid='{$arcID}'{$titleSet} WHERE url LIKE '{$v}'; ");
            }
        }
    }
    $artUrl = MakeArt($arcID, TRUE, TRUE, $isremote);
    if ($artUrl == '') {
        $artUrl = $cfg_phpurl . "/view.php?aid=$arcID";
    }
    ClearMyAddon($arcID, $title);
    //返回成功信息
    $msg = "    　　请选择你的后续操作：
    <a href='article_add.php?cid=$typeid'><u>继续发布文章</u></a>
    &nbsp;&nbsp;
    <a href='$artUrl' target='_blank'><u>查看文章</u></a>
    &nbsp;&nbsp;
    <a href='archives_do.php?aid=" . $arcID . "&dopost=editArchives'><u>更改文章</u></a>
    &nbsp;&nbsp;
    <a href='catalog_do.php?cid=$typeid&dopost=listArchives'><u>已发布文章管理</u></a>
    &nbsp;&nbsp;
    $backurl
  ";
    $msg = "<div style=\"line-height:36px;height:36px\">{$msg}</div>" . GetUpdateTest();
    $wintitle = "成功发布文章！";
    $wecome_info = "文章管理::发布文章";
    $win = new OxWindow();
    $win->AddTitle("成功发布文章：");
    $win->AddMsgItem($msg);
    $winform = $win->GetWindow("hand", "&nbsp;", FALSE);
    $win->Display();
}
?>